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(57) In a memory apparatus, there are provided a 
mirror primary LU (261) which is a memory region on a 
plurality of storage media (271 -275) formed of nD+1 P, 
a mirror secondary LU (262) that is a memory region on 
a plurality of storage media (281 -287) formed of mD+1 P, 
an n-RAID control sub-program (236) for performing 
RAID control of nD+1 P, an m-RAID control subprogram 
(237) for performing RAID control of mD+1 P, and an LU 
mirror subprogram (231) for performing writing into the 
mirror primary LU and mirror secondary LU and then ef- 
fectuating duplexing or "mirroring" when a computer 
(100) issues a data write request. The "m" and "n" are 
different integers more than or equal to 2. 
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Description 

BACKGROUND OF THE INVENTION 

[0001] The present invention relates to a method for 5 
management of storage or "memory" regions in external 
memory device systems of computers and, in more par- 
ticular, to a management method as to snap shots. 
[0002] In memory devices such as fixed or "hard" disk 
drives (HDDs), it is required that data as recorded on a 
memory device be periodically copied for storage (back- 
up) to another memory device such as a magnetic tape 
storage device for future use in the case of disappear- 
ance of data due to operation failure or obstruction of 
the memory device, software program defects, opera- 
tion errors and the like. In such case, the data of interest 
for use as an object to be backed up (original data) will 
be updated during the backup; if mismatch is found be- 
tween the backed up data and the data priorto execution 
of backup, then it will no longer be possible to reproduce 
any data at a time point that the backup gets started. 
Due to this, it is required to guarantee the matchability 
of data during copy operations. 

[0003] To guarantee the matchability of data to be 
backed up, programs other than a backup program may 
be interrupted or halted while the backup program is be- 
ing operating in a computer system. However, with a 
system under requirement for higher availability func- 
tions, it is impossible to interrupt the program for a long 
time. Due to this, there is required a systematic mech- 
anism for forming in more than one backup-use memory 
device a layout location (to be referred to as "memory 
image" hereinafter) of data and the content of data as 
stored in a memory device at a backup startup time point 
while at the same time permitting any program to update 
data during backup operations. Here, let the memory im- 
age of data at a given time point be called a snap shot. 
In addition, let the mechanism for providing the state ca- 
pable of updating data while forming a snap shot at any 
designated time point be called a snap shot manage- 
ment method. Additionally let the activity of forming a 
snap shot by the snap shot management method be 
called snap shot acquisition. Additionally let withdrawal 
of the state that has formed a snap shot be called snap 
shot deletion. 

[0004] Prior known snap shot management methods 
include a method for duplexing or "mirroring" data. 
[0005] With this method, in an ordinary or normal state 
in which any snap shots are not acquired yet, a program 
on a computer duplexes and stores all the data items in 
two separate memory regions. Upon acquisition of a 
snap shot, the duplexing or "mirroring" procedure is in- 
terrupted causing one region to be provided as the orig- 
inal data while letting the other region be provided as a 
snap shot. 

[0006] In cases where update of the original data oc- 
curs during interruption of the mirroring, the position of 
any data thus updated is to be recorded. In a snap shot 
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deletion event, data mirroring gets started again, in ad- 
dition, based on a record of the position of such updated 
data, the updated data will be copied from the original 
data memory region to the other memory region. This 
copy operation will be called the mirror resynchroniza- 
tion. A method of mirroring data by use of a program on 
a computer is disclosed in U. S. Patent No. 5,051,887 
to Blaine H. Berger et al. 

[0007] The above-noted two regions are generally 
constituted from a disk array in most cases. The disk 
array is arranged so that a plurality of disk devices are 
laid out into an array-like form. A memory device system 
including such disk array will be called the disk array 
apparatus hereinafter. The disk array apparatus is a 
memory apparatus which processes read and write re- 
quests from an upper-level or "supervisory" computer 
equipment (host) through parallel operations of disk de- 
vices at high speeds while at the same time improving 
the reliability by adding redundant data to the data being 
handled. The disk array can also be called the redun- 
dant array of inexpensive disks (RAID). Disk arrays are 
typically categorized into five levels depending upon the 
type and arrangement of the redundant data. 
[0008] To ensure that the rate of access to a memory 
region with the original data being stored therein does 
not decrease during the use of a snap shot, the memory 
region of original data and the memory region of snap 
shot are formed of physically different disk arrays re- 
spectively. !n addition, let the arrangement of disk de- 
vices in a disk array be represented by "nD+1 P," where 
D is a disk device with data stored therein, and P is a 
disk device with redundant data stored therein. The for- 
mula nD+1 P indicates the arrangement of n data record- 
ing disk devices and a single disk device with redundant 
data stored therein. Considering based on the arrange- 
ment of such disk devices, a disk array in which original 
data memory regions are laid out and a disk array in 
which memory regions used for snap shots are disposed 
are designed to have the same number of disk devices, 
that is, a configuration having the same n, wherein those 
being the same in storage capacity of individual disk de- 
vices are employed. 

[0009] From several view points of performance and 
reliability plus costs or the like, different features are re- 
quired for the memory region in which the original data 
is to be stored therein and for the memory region used 
for snap shots. One example is that the reliability is 
thought to be important in the memory region with the 
original data being stored therein whereas lower bit 
costs are required for the memory region used for snap 
shots. Additionally in some cases, higher performance 
is required for the memory region being used for snap 
shots in order to speed up the intended backup opera- 
tions. 

[0010] To be brief, it should be strictly required that 
each disk array be made up of specific disk devices dif- 
ferent in performance, record density, storage capacity, 
reliability and the like. In this case, since the features 
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required can be realized depending on the scheme for 
arranging the disk array (nD+1 P), it is required that re- 
spective ones of the disk arrays with the original data 
memory region and the memory region used for snap 
shots being disposed therein be configured from nD+1 P 5 
configurations having mutually different n values. How- 
ever, in the prior art, it has been impossible or at least 
greatly difficult to realize any successful combination of 
disk arrays in which mutually flexible arrangements are 
employed. 

SUMMARY OF THE INVENTION 

[001 1] It is therefore an object of the present invention 
to provide, in a disk array implemented to operate based 
on duplex/mirroring architectures in order to acquire 
snap shots used forbackup sessions, a method capable 
of permitting respective disk arrays to employ mutually 
flexible arrangements by arranging the disk arrays each 
having a memory region with original data stored therein 
and a memory region used for a snap shot so that these 
have disk arrangements of nD+1 P having mutually dif- 
ferent n values. 

[0012] To attain the foregoing object, the present in- 
vention provides, in a disk array as implemented to op- 
erate based on duplex or "mirroring" architectures in or- 
der to acquire a snap shot or shots, a mirror primary log- 
ical unit (LU) that is a memory region on a plurality of 
memory media arranged by nD+1 P, a mirror secondary 
LU that is a memory region on a plurality of memory me- 
dia arranged by mD+1 P, an n-RAID control sub-program 
for performing RAID control of nD+1 P, an m-RAID con- 
trol subprogram for performing RAID control of mD+1 P, 
and an LU mirror subprogram which writes into the mir- 
ror primary LU and the mirror secondary LU when a 
computer requests data write to thereby execute du- 
plexing or "mirroring." Note here that the parameters "m" 
and "n" are integers more than or equal to two (2) and 
that m and n are different values. 

BRIEF DESCRIPTION OF THE DRAWINGS 

[0013] 

Fig. 1 is a diagram showing an overall configuration 
of a system in accordance with a first preferred em- 
bodiment of the present invention. 
Fig. 2 is a diagram showing an updated position 
management table used in the first embodiment. 
Fig. 3 depicts a snap-shot acquisition/deletion flow 
in the first embodiment. 

Fig. 4 is a flow diagram of an operation of a mirror 
re-synchronous sub-program in the first embodi- 
ment. 

[0014] Fig. 5 is a diagram showing, in table form, a 
relationship of a mirror primary LU and a mirror second- 
ary LU in the first embodiment in case the data recording 
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disk device numbers n and m are set n<m. 
[0015] Fig. 6 is a diagram showing in table form a re- 
lation of the mirror primary LU and mirror secondary LU 
in the first embodiment in the case of n>m, along with 
an internal structure of each LU. 
[0016] Fig. 7 is a diagram showing a system configu- 
ration in a second embodiment of the invention. 

DESCRIPTION OF THE EMBODIMENTS 

[001 7] Referring to Fig. 1 , there is depicted an overall 
arrangement of a computer system with data duplex/ 
mirroring functionality in accordance with a first pre- 
ferred embodiment of the present invention. 
[0018] The illustrative system has a computer 100 
and a disk array apparatus 200. 
[001 9] The computer 1 00 has a central processor unit 
(CPU) 110, a memory 120, and an interface 140 based 
on the currently established small computer system in- 
terface (SCSI) standards-say, SCSI interface. This SC- 
SI interface 1 40 is connected to the disk array apparatus 
200 via a SCSI data bus 300. The memory 120 stores 
therein a database program 126 and backup program 
127. The both programs are executed by the CPU 11 0. 
[0020] Although in this embodiment a back-up oper- 
ation will be discussed as an utilization example of snap 
shots, the present invention will also be utilizable for oth- 
er purposes such as on-line analytical processing 
(OLAP) and/or system testing and the like. 
[0021] The database program 126 has a function of 
providing access to a logical unit (LU) 261 as will be de- 
scribed later in the description and also has a function 
of controlling data updating to the LU 261 to thereby ex- 
ecute a backup mode for guarantee of the matchability 
of data within the LU 261. The database program 126 
shifts into the backup mode upon receipt of an instruc- 
tion from either a user or the backup program 127. The 
backup program 127 has a function of reading data in 
order to back up data to a magnetic tape storage device 
such as tape cartridges or else (not shown) from an LU 
262 with more than one snap shot saved therein in ac- 
cordance with an instruction from the user, a function of 
issuing a "ModeSelect" command of SCSI toward the 
disk array apparatus 200, and a function of instructing 
to the database program 1 26 whether the backup mode 
is made valid or invalid-namely enabled or disabled. 
[0022] The disk array apparatus 200 has a CPU 21 0, 
memory 220, SCSI interface 240, disk control unit or 
controller 250, and two separate disk device groups or 
assembles 251-252. Stored in the memory 220 is a snap 
shot management program 221 . This program is to be 
executed by the CPU 21 0. 

[0023] The disk device assembly 251 is a disk array 
which has a group of disk devices 271 to 275. The disk 
device assembly 252 is a disk array that has another 
group of disk devices 281 -287. Each disk device assem- 
bly has a disk configuration of RAID level 5 with parity- 
added striping (i.e. striping with mirroring) being applied 
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thereto. Note that although in this embodiment the disk 
device assembly 251 is set at 5 in number of disk devic- 
es whereas the disk device assembly 252 is 7 in disk 
device number, any available configurations are em- 
ployable as far as the requisite number of disk devices 
in each disk device assembly is set at 3 or more and at 
the same time the disk device assemblies 251-252 are 
designed so that these are different in disk device 
number from each other. In the rest of the description, 
the numbers of disk devices of the disk device assem- 
blies 251 -252 will be represented as "nD+1 P," "mD+1 P," 
respectively. In this embodiment, n=4, m=6. In the 
present invention the parameters "n" and "m" as used 
herein are integers greater than or equal to 2 while let- 
ting n and m be different values. 

[0024] The disk device assemblies 251-252 provide 
the computer 100 with memory regions owned by the 
plurality of disk devices as a single logical memory re- 
gion. Practically, a logical unit (LU) that satisfies SCSI 
standards is provided to the computer 100. Let an LU 
as provided by the disk device assembly 251, 252 be 
LU 261 , 262. Optionally a plurality of LUs may be pro- 
vided within each disk device assembly 251 , 252 when 
the need arises. 

[0025] In this embodiment the snap shot manage- 
ment program 221 within the disk array 220 is designed 
to perform management while letting the LU 261 func- 
tion as a mirror primary LU having original data and also 
letting the LU 262 act as a mirror secondary LU operable 
to store therein data of a duplicate copy or "mirror" of 
the original data. The LU 262 is for use as a snap shot(s). 
[0026] The snap shot management program 221 of 
the disk array apparatus 200 has a disk access sub-pro- 
gram 230 for instruction of disk access to the disk con- 
troller 250 in accordance with a request from the com- 
puter 100, and an LU mirror subprogram 231 for duplex- 
ing or "mirroring*' the update of data with respect to the 
LU 26 1 while also updating the data of LU 262 to thereby 
write the same user data into such two LUs. 
[0027] The snap shot management program 221 of 
the disk array apparatus 200 also has an n-RAID control 
subprogram 236 and m-RAID control subprogram 237. 
The n-RAID control subprogram 236 controls the disk 
devices 271 -275 as RAID 5 of nD+1 P. The m-RAID con- 
trol subprogram 237 controls the disk devices 281-287 
as RAID 5 of mD+1 P. 

[0028] Further, the snap shot management program 
221 has a non-mirror event update monitor subprogram 
234 which detects the presence or absence of data up- 
date with respect to the mirror primary LU 261 for use 
as a mirror primary when the disk array apparatus 200 
is halting or interrupting the duplex/mirroring processing 
(in a non-mirror event), a non-mirror event update posi- 
tion management subprogram 235 which records an up- 
dated position of data into an update position manage- 
ment table 222 to be later described, and a mirror re- 
synchronous subprogram 232 which copies any updat- 
ed portion or portions of the mirror primary "source" LU 
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261 to the mirror secondary "destination" LU 262 upon 
execution of mirror resynchronization. 
[0029] Fig. 2 is a diagram showing an arrangement of 
the update position management table 222. The update 

5 position management table 222 has regions for storage 
of logical block address (LBA) set numbers within the 
mirror primary LU 261 and updated bits corresponding 
to the LBA set numbers. LBA set is the individual partial 
region when the LU is subdivided from its top with more 

10 than one LBA being as a unit. The LBA set numbers are 
serial numbers which are assigned to the LBA sets. An 
update bit is indicative of whether any LBA set of the 
mirror primary LU 261 has been updated in the non-mir- 
ror event, to which 1 , 0 will be designated in accordance 

15 with "update" and "non-update," respectively. The initial 
set or "default" value of such update bit is 0. With the 
example of Fig. 2, there is shown the state that only a 
region of the LBA set number 1 has been updated in the 
non-mirror event. 

20 [0030] Fig. 3 is a flow chart showing operations of the 
backup program 127 and the snap shot management 
program 221 in snap-shot acquisition/deletion events. 
Here, an explanation will be given of a case where the 
LU 262 for use as a mirror secondary LU of the mirror 

25 primary LU 261 is provided as a snap shot of LU 261 . 
[0031 ] As shown in Fig. 3, the backup program 1 27 of 
the computer 100 gives an instruction to the database 
program 126 and then validates or "enables" a backup 
mode to thereby guarantee the matchability of data for 

30 acquisition of a snap shot (at step 2000). Next, the back- 
up program 127 issues to the disk array apparatus 200 
a ModeSelect command for acquisition of a snap shot 
(at step 2001). Upon receipt (3000) of the ModeSelect 
command, the snap shot management program 221 of 

35 disk array apparatus 200 makes effective both the non- 
mirror event update monitor subprogram 234 and the 
non-mirror event update position management subpro- 
gram 235 and then starts update position recording of 
the LU 261 (at 3001). Thereafter, when the data of LU 

40 261 is updated, an update bit of an LBA set including 
the updated LBA in the update position management ta- 
ble 222 is set at 1 . 

[0032] Next, the snap shot management program 221 
makes invalid or "disables" the LU mirror subprogram 

45 231 and then instructs termination of the duplex/mirror- 
ing processing of the data of LU 261 and LU 262. Where- 
by, data updating with respect to the LU 261 presently 
serving as the mirror primary LU will no longer be re- 
flected on the LU 262 that acts as the mirror secondary 

so LU (at step 3002 of Fig. 3). Next the snap shot manage- 
ment program 221 sends forth an end status of the 
ModeSelect command toward the backup program 1 27 
of the computer 100 (at step 3003). Upon receiving of 
the end status of ModeSelect command (at 2002), the 

55 backup program 127 gives an instruction to the data- 
base program 126 for invalidation of the backup mode 
(2003). 

[0033] Next, the backup program 127 issues to the 
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disk array apparatus 200 a ModeSelect command which 
instructs snap shot deletion (at step 2004). Upon receipt 
of such ModeSelect command (at 3005), the snap shot 
management program 221 of disk array apparatus 200 
validates the LU mirror subprogram 231 and then again 5 
starts or "restarts" mirroring of the LU 261 and LU 262 
(3006). Whereby, the updating relative to LU 261 will be 
reflected on LU 262 also. 

[0034] Next, the snap shot management program 221 
invalidates the non-mirror event update monitorsubpro- 
gram 234 and the non-mirror event update position 
management subprogram 235 and then halts update 
position recording of the LU 261 (at step 3007). There- 
after, the non-mirror event update position management 
subprogram 235 will no longer change the update bits 
of the update position management table 222. 
[0035] Next the snap shot management program 221 
validates the mirror asynchronous subprogram 232. 
The mirror resynchronous subprogram 232 refers to the 
update position management table 222 and then copies 
a portion with the LU 261 failing to be identical in content 
to the LU 262 from the LU 261 to LU 262 to thereby per- 
form the intended mirror resynchronization (at step 3008 
of Fig. 3). Once the ^synchronization is terminated, the 
snap shot management program 221 invalidates the 
mirror resynchronous subprogram 232 (at step 3009) 
and then transfers an end status of ModeSelect com- 
mand toward the backup program 127 of the computer 
100 (at 3010). The backup program 127 that has re- 
ceived the end status of ModeSelect command finishes 
its operation (2005). 

[0036] The backup program 1 27 of the computer 1 00 
performs reading of the LU 262 that has acquired a snap 
shot in a session covering the step 2003 and step 2004 
and then executes backup of such data in another mem- 
ory device (not shown). 

[0037] An explanation will be given of an operation of 
the mirror resynchronization for copying data from the 
LU 261 to LU 262 at step 3008 of Fig. 3. 
[0038] See Fig. 5, which is a diagram showing a rela- 
tionship of the LU 261 , LU 262 and update position man- 
agement table 222 in case the disk array arrangement 
of LU 261 and LU 262 is n<m. 

[0039] The LU 261 is arranged so that a single parity 
is assigned to four LBA sets of data. One example is 
that a parity PnO is assigned relative to LBA sets 0 to 3. 
The parity PnO is the value that is subjected to an ex- 
clusive-OR (Ex-OR) operation of the LBA sets 0-3. Sim- 
ilarly a parity Pn 1 is assigned to LBA sets 4-7; parity Pn2 
is to LBA sets 8-11 . Here, the plurality of LBA sets and 
a parity corresponding to a combination of such LBA 
sets will be called together as a "stripe array." For in- 
stance, the LBA sets 0-3 and parity PnO make up a stripe 
array. Note that although with RAID 5 the parities are 
dispersed and laid out in each disk device while exhib- 
iting rotation, suppose in this embodiment that a unit of 
rotation is significant and thus any situation of dispersal 
layout will hardly appear in the case shown in the draw- 



ing. 

[0040] The LU 262 is arranged so that a single parity 
is assigned to six (6) LBA sets of data. For example, a 
parity PmO is assigned to LBA sets 0 to 5. 
[0041] It must be noted that data duplex/mirroring is 
executed between certain memory regions which are 
the same in LBA set numbers of the LU 261 and LU 262. 
[0042] In Fig. 5, in order to indicate the relation of the 
update position management table 222 versus the LU's 
stripe array, a stripe partition of the LU 261 and LU 262 
is additionally written on the left side of the update po- 
sition management table 222. Note that as n and m are 
different in value from each other, a deviation would take 
place in the stripe partition of LU 261 and LU 262. 
[0043] In the event of mirror resynchronization, an 
LBA set that fails to coincide in content between the LU 
261 and LU 262 is copied from LU 261 to LU 262. At 
this time, data read processing is performed with re- 
spect to LU 261 whereas data write processing is done 
relative to LU 262. 

[0044] In case data write is done to a disk array with 
its arrangement of RAID 5, in order to establish parity 
matching, read data of any update-free LBA set within 
the stripe array, and then execute an Ex-OR (XOR) op- 
eration including new data to thereby generate a new 
parity; thereafter, an operation for writing such new par- 
ity and new data into a disk device is performed. In this 
way, in the event of data writing to the disk array, a phe- 
nomenon that the number of access to those other than 
the data-written disk device increases is called the "write 
penalty." 

[0045] It should be noted that in case data items of all 
the LBA sets of the stripe array are to be updated, a new 
parity is generated only from the LBA set to be written. 
In other words, it is no longer required to read the data 
of any update-free LBA sets within the stripe array in 
order to prepare the parity. Accordingly, this results in a 
mere increase in parity writing; thus, it is possible to ac- 
complish the required task with minimal write penalty. 
[0046] Assume here that a value "1" is set in the up- 
date bits of LBA set numbers 7 to 1 0 of the update po- 
sition management table 222 and also that data of the 
condition-fulfilled LBA sets 7-10 during mirror resyn- 
chronization will be copied from the LU 261 to LU 262. 
[0047] In an ordinary or normal copying session, read 
the data of LBA sets 7-1 0 of the LU 261 as surrounded 
by a thick lined or "fat" frame and then write into LBA 
sets 7-1 0 of LU 262 surrounded by a fat frame. In addi- 
tion thereto, in order to establish parity matchability of 
the stripe array of LU 262, read an LBA set 6 and LBA 
set 11 of LU 262 as indicated by oblique lines; then, write 
into Pm1 of a disk device 287 a parity as has been gen- 
erated through arithmetical processing of XOR with re- 
spect to LBA sets 7-1 0 of LU 261 . Accordingly, in addi- 
tion to parity write, read access must be done for reading 
the LBA set 6 and LBA set 11 of LU 262. 
[0048] In the present invention, in order to suppress 
any possible write penalties, the n-RAID control subpro- 
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gram 236 reads out of the LU 261 rather than LU 262 
the data of LBA set 6 and LBA set 11 as indicated by 
oblique lines, and then prepares data for parity genera- 
tion of the stripe array of LU 261 . Thus it is no longer 
required to read the data of the LBA set 6 and LBA set 
11 of LU 262 as indicated by oblique lines. Additionally, 
disk access to disk devices 271 -274 would occur upon 
reading of the data of LBA sets 7-1 0 of LU 261 ; in such 
case, when reading the LBA set 10, consecutively read 
the LBA set 6 also in responding to receipt of a single 
disk command. Similarly, when reading the LBA set 7, 
consecutively read the LBA set 1 1 also in response to a 
single disk command. Disk access time includes a 
processing time in which a seek time of a read/write 
head assembly within a disk device and a rotation wait 
time of disk-like round plate(s) occupy major part there- 
of. Thus it is possible by reading the data in reply to a 
single disk command to eliminate or omit any rotation 
wait time of disk plate(s), which in turn makes it possible 
to reduce a disk access time relative to the LBA sets 6, 
11. 

[0049] To be brief, in the present invention, in cases 
where more than one LBA set is present which requires 
copying for mirror resynchronization, the n-RAID control 
subprogram 236 attempts to read data from the mirror 
primary LU in such a way as to permit assortment of all 
the LBA sets in the stripe array of the mirror secondary 
LU including a copy-necessary LBA set(s). 
[0050] Determination of an LBA set(s) requiring read- 
ing from the mirror primary LU is performed in a way 
which follows. In this embodiment, the LU 262 for use 
as the mirror secondary LU is m=6. Accordingly a single 
stripe array of the mirror secondary LU is made up from 
LBA blocks as designated by LBA set numbers of 6xp 
through 6xp+5, where p is an integer greater than or 
equal to 0. An LBA set number within the stripe array 
including a copy-required LBA set(s) for mirror resyn- 
chronization is specified by obtaining p as an integer 
part of the number of such copy-required LBA set for 
mirror resynchronization as divided by m=6. 
[0051] For instance, in case an update bit correspond- 
ing to LBA set number 7 is 1 , it becomes the integer part 
resulted from division of 7 by 6, that is, p=1 ; the number 
of an LBA set requiring reading is 6Xp to 6xp+5, i.e. 
LBA set numbers 6 to 11 . The n-RAID control subpro- 
gram 236 determines the exact position of any to-be- 
read LBA set on the basis of the LBA set number as has 
been specified from this p value and then reads data. 
[0052] At the mirror secondary LU, the m-RAID con- 
trol subprogram 237 executes writing of a copy-neces- 
sary LBA set and writing of a parity thus generated. 
[0053] Additionally, detection of such copy- necessary 
LBA set is performed by letting the mirror resynchronous 
subprogram 232 refer to the update position manage- 
ment table 222. In case the copy-necessary LBA set is 
found within the stripe array of the mirror secondary LU, 
the mirror resynchronous subprogram 232 operates in 
such a way that it conducts a search to determine wheth- 



er any other copy-necessary LBA sets are present with- 
in the same stripe array and, if any, copies such other 
LBA sets also. More specifically, the mirror resynchro- 
nous subprogram 232 searches for any LBA block with 
5 the update bit of update position management table 222 
being presently set at 1 . If such LBA set with its bit of 1 
is found then the mirror resynchronous subprogram 232 
refers to the update bit corresponding to another LBA 
set within the stripe array including such LBA set thus 
10 found and then verifies whether an LBA set of 1 is 
present or not. After having verified the LBA block with 
its update bit of 1 within the same stripe array, the mirror 
resynchronous subprogram 232 sends forth toward the 
m-RAID control subprogram 237 an instruction for per- 
forming copying with respect to any condition-fulfilled 
LBA block(s). In addition, it notifies the n-RAID control 
subprogram 236 of the value of p and then sends an 
instruction for reading an LBA block corresponding to p. 
[0054] It is to be noted here that although the expla- 
nation above was given under an assumption that the 
mirror resynchronous subprogram 232 searches the up- 
date position management table 222 with respect to 
every stripe array of the mirror secondary LU, in case 
the copy-necessary LBA set bridges between neighbor- 
ing stripe arrays in the mirror secondary LU, it may be 
modified to operate in such a way as to conduct a search 
to determine whether any other copy-necessary LBA 
sets are present within a plurality of neighboring stripe 
arrays also and then copy such other LBA sets also. 
[0055] Also note that in view of the fact that there still 
remains the case incapable of reducing the disk access 
number, an alternative arrangement may also be em- 
ployed which performs calculation of the read position 
of the LU 261 and the write position of the LU 262 in a 
way such that whenever detection is made of a normal 
copy, i.e., an LBA block with its update bit being pres- 
ently set at 1 , let the n-RAID control subprogram 236 
and m-RAID control subprogram 237 immediately per- 
form reading and writing of the subject LB blocks. 
[0056] Fig. 6 is a diagram showing the LU 261, LU 
262 and update position management table 222 in case 
the disk array arrangement of LU 261 and LU 262 is 
n>m. Here, an explanation will be given in the case of 
n=4, m=3. 

[0057] The LU 261 shown herein is the same as that 
of Fig. 5. 

[0058] The LU 262 is arranged so that a single parity 
is assigned to three LBA sets of data. 
[0059] In a similar way to the case of Fig. 5, a stripe 
partition of the LU 261 and LU 262 is additionally written 
on the left side of the update position managementtable 
222. 

[0060] An explanation will be given of the case where 
update bits of the LBA set numbers 4-7 of the update 
position management table 222 are set at 1 and where 
data items of the subject LBA sets 4-7 are copied to- 
gether from the LU 261 to LU 262 during mirror resyn- 
chronization processing, by way of example. 
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[0061] In the case of normal copying, read the LBA 
sets 4-7 of the LU 261 as surrounded by a fat frame; 
then, write into LBA sets 4-7 of the LU 262 surrounded 
by fat frame. Simultaneously, read an LBA set 3 and LBA 
set 8 of the LU 262 as indicated by oblique lines in order 5 
to establish the parity matchability of stripe arrays of LU 
262. Then, execute XOR with the LBA set 3 as has been 
read out of the LBA sets 4-5 of LU 261 . Next, write the 
parity thus generated into Pm 1 of a disk device 284. Ad- 
ditionally, write into Pm2 of the disk device 284 a parity 
that was generated by execution of XOR with the LBA 
sets 6-7 of LU 261 and LBA set 8 read out of LU 262. 
Therefore, read access to the disk devices 281 , 283 
takes place in order to read the LBA sets 3, 8 of LU 262 
other than writing of the parity. 

[0062] In contrast thereto, in the present invention, in 
order to lighten and reduce any possible write penalties, 
the n-RAID control subprogram 236 reads the LBA set 
3 and LBA set 8 as indicated by oblique lines from the 
LU 261 rather than from the LU 262 and then prepares 
data for parity generation of the stripe arrays of LU 261 . 
Thus it is no longer necessary to read the LBA set 3 and 
LBA set 8 indicated by oblique lines of the LU 262. In 
addition, although disk access must occur to the disk 
devices 271-274 during reading of the LBA sets 4-7 of 
LU 261 for copying purposes, in such case, LBA set 3 
is also read consecutively by a single disk command 
when reading LBA set 7. Similarly when reading LBA 
set 4, LBA set 8 also is consecutively read by a single 
disk command. Reading data by a single disk command 
makes it possible to reduce a time for disk access to 
LBA sets 3, 8. 

[0063] In brief, in accordance with this invention, 
whenever an LBA set necessary with copy for mirror re- 
synchronization is present, the n-RAID control subpro- 
gram 236 reads an alternative LBA set from the mirror 
primary LU to thereby permit assortment or equalization 
of all the LBA sets within the stripe arrays of the mirror 
secondary LU including LBA sets. In this event, if an LBA 
set alternative to the LBA set of the mirror secondary LU 
is present within the disk device of the mirror primary LU 
that stores therein any LBA set with a need for copy for 
resynchronization purposes, then a time taken to per- 
form reading is shortened in a similar way to that of Fig. 
5. With respect to the mirror secondary LU, the m-RAID 
control subprogram 237 executes writing of a copy-nec- 
essary LBA set(s) and writing of a parity thus generated. 
[0064] Additionally, detection of such copy-necessary 
LBA set(s) is performed by the mirror resynchronous 
subprogram 232 by referring to the update position man- 
agement table 222 in a similar way to the case of Fig. 5. 
[0065] Also note that in view of the fact that disk ac- 
cess number reduction is hardly possible in some cases, 
the read position of LU 261 and the write position of LU 
262 may be calculated in such a way as to perform nor- 
mal copying. 

[0066] Fig. 4 is a flow chart showing an operation of 
the mirror resynchronous subprogram 232 at the time 



of mirror resynchronization. 

[0067] Firstly, the mirror resynchronous subprogram 
232 conducts investigation to determine whether 1 is 
present as an update record in the update bits of the 
update position management table 222 (at step 1001). 
If the update record value "1" is absent then terminate 
processing since the mirror resynchronization was com- 
pleted (at step 1002). 

[0068] In case the value "1 " is present at the updated 
bits, the mirror resynchronous subprogram 232 com- 
putes both a read position of the LU 261 and write po- 
sition of LU 262 in a way as has been explained in con- 
junction with Figs. 5 and 6 (at step 1003). Next, inhibit 
updating of any subject read/write positions (at 1004); 
then, based on the read/write positions thus computed, 
the n-RAID control subprogram 236 and m-RAID control 
subprogram 237 make use of the method as has been 
explained in Fig. 5 and Fig. 6 to copy any condition-ful- 
filled data from the LU 261 that functions as the mirror 
primary LU to the LU 262 acting as the mirror secondary 
LU(1005). 

[0069] Next, the mirror resynchronous subprogram 
232 releases the update inhibition of any applicable 
read/write positions (at step 1 006) and then sets 0 at an 
update bit at the position which is present within the up- 
date position management table 222 and was mirrored 
by copying to thereby delete the update record (at 
1007); thereafter, return to step 1001 . 
[0070] An explanation will be given of an operation of 
the computer 1 00 during data read and write plus snap 
shot reading. 

[0071] First, an operation of the database program 
1 26 in case the computer 1 00 provides access to data 
of the LU 261 in the disk array apparatus 200 will be 
explained. The database program 126 performs the 
same operation irrespective of whether snap shot ac- 
quisition is present or absent. 

[0072] In case the database program 1 26 reads data 
of the LU 261 , the database program 126 issues to the 
disk array apparatus 200 a "READ" command for read- 
ing the data of LU 261 . The database program 126 re- 
ceives data and a status from the disk array apparatus 
200 and then terminates its operation. Alternatively in 
case the database program 1 26 writes data into LU 261 , 
the database program 126 issues to the disk array ap- 
paratus 200 a "WRITE" command for writing data into 
the LU 261 and then transfers data. The database pro- 
gram 1 26 receives a status from the disk array appara- 
tus 200 and then finishes its operation. 
[0073] An explanation will next be given of an opera- 
tion of the backup program 127 in the event that the 
computer 100 reads a snap shot of the LU 261 that ex- 
ists in the disk array apparatus 200. 
[0074] In case the backup program 1 27 reads a snap 
shot of the LU 261 , the backup program 127 issues to 
the disk array apparatus 200 a READ command for 
reading data of LU 262 which serves as the mirror sec- 
ondary LU of the LU 261 . The backup program 127 re- 



ts 



20 



25 



30 



35 



40 



45 



50 



13 



EP 1 237 087 A2 



14 



ceives data and status from disk array apparatus 200 
and then ends its operation. 

[0075] An operation of the disk array apparatus 200 
during data reading and writing plus snap shot reading 
will be explained below. 

[0076] First, an operation of the snap shot manage- 
ment program 221 in the event that the computer 100 
gives access to the data of the LU 261 residing in the 
disk array apparatus 200 will be explained. 
[0077] I n case the computer 1 00 reads data of the LU 
261 , the snap shot management program 221 receives 
a "READ" command with respect to LU 261 . Next, if the 
LU mirror subprogram 231 is presently validated and al- 
so if copy of an updated portion due to the mirror asyn- 
chronous subprogram 232 has been completed then the 
snap shot management program 221 reads data out of 
either the LU 261 ortheLU262 acting as the mirror sec- 
ondary LU. Otherwise, it reads data from LU 261 . After 
having read the data, the snap shot management pro- 
gram 221 transfers both the read data and status toward 
the computer 100. In case the LU 261 and the LU 262 
acting as the mirror secondary LU are identical in con- 
tent to each other, load is distributed by reading data 
from either one of the both. 

[0078] In case the computer 1 00 writes data into the 
LU 261 , the snap shot management program 221 re- 
ceives a "WRITE" command and data with respect to 
the LU 261 . Next, if the LU mirror subprogram 231 is 
presently effective then the snap shot management pro- 
gram 221 writes data into the LU 261 and the LU 262 
serving as the mirror secondary LU; if invalid then write 
data into LU 261 . Next, if both the non-mirror event up- 
date monitor subprogram 234 and non-mirror event up- 
date position management subprogram 235 are effec- 
tive then the snap shot management program 221 sets 
1 to the update bit of an LBA set including the data of 
LU 261 as updated relative to the update position man- 
agement table 222; if invalid then it does nothing. Lastly, 
send a status to the computer 1 00. 
[0079] An operation will next be given of an operation 
of the snap shot management program 221 in cases 
where the computer 100 reads a snap shot of the LU 
261 residing in the disk array apparatus 200. 
[0080] In case the computer 1 00 reads a snap shot of 
the LU 261 , the snap shot management program 221 
receives a READ command with respect to the LU 262 
serving as the mirror secondary LU of LU 261 . Next the 
snap shot management program 221 reads data out of 
the LU 262 acting as the mirror secondary LU. After hav- 
ing read the data, the snap shot management program 
221 sends forth the read data and status toward the 
computer 100. 

[0081] Note here that while any updated portion is be- 
ing copied and duplicated by the mirror resynchronous 
subprogram 232, data access performance decreases 
due to the fact that the copy processing and the data 
access processing to the LU 261 by the computer 1 00 
are concentrated on the same LU 261 . 



[0082] In accordance with this embodiment, in the 
disk array apparatus employing the duplex/mirroring 
scheme for snap shot acquisition, in case n and m are 
set at certain integers greater than or equal to 2 and are 

5 of different values, it becomes possible to assembly 
both the disk array having a memory region of the orig- 
inal data and the disk array having a memory region for 
provision as a snap shot into disk arrangements of 
nD+1 P and mD+1 P, respectively; thus, there is an effect 

10 which enables each disk array to employ a flexible con- 
figuration. 

[0083] Thus, it is possible to keep pace with the re- 
quirements to the memory region of the original data and 
to the memory region for provision as a snap shot when 

15 looking at in viewpoints of performance, reliability, costs 
and the like. For example, consider one specific case 
where the same disk device is used to constitute the 
memory region of original data into 4D+1 P while arrang- 
ing the memory region for provision as a snap shot into 

20 8D+1 P. With regard to the reliability, 4D+1P significant 
in ratio of redundancy disk device number offers supe- 
riority; on the other hand, regarding bit costs, 8D+1 P 
less in ratio of redundancy disk device number is more 
excellent. Assuming that the case where the disk device 

25 becomes a bottle neck of the performance, consecutive 
data read performance as a disk array is such that 
8D+1 P offers the performance two times greater than 
the other. In this way, by establishing mirroring at the 
disk arrays different in nD+1 P, it becomes possible to 

30 successfully accommodate a variety of requirements to 
the memory region of original data and the memory re- 
gion for provision as a snap shot. 
[0084] In addition, although snap shot management 
methods employing data duplex/mirroring schemes are 

35 faced with a problem that both normal access for doing 
update/referring and copy access of update data are 
concentrated on the memory region of original data at 
the time of mirror resynchronization causing the normal 
access to decrease in performance, the embodiment 

40 discussed above offers an advantage which follows: it 
is possible by reading the mirror primary LU in a way 
synchronous with the stripe arrays of a mirror secondary 
LU to shorten a mirror resynchronization time which oth- 
erwise results in a decrease in performance. 

45 [0085] Note here that although in the present inven- 
tion the interface for connection between the computer 
100 and disk array apparatus 200 is designed by the 
SCSI bus 300, other interfaces may be employed such 
as fibre channels or else. 

so [0086] Turning to Fig. 7, there is shown a configura- 
tion of a computer system with duplex/mirroring archi- 
tecture in accordance with a second embodiment of this 
invention. 

[0087] The embodiment of Fig. 7 is the one that incor- 
55 porates the principles of the present invention into a 
computer system in which the disk device assemblies 
in the first embodiment are arranged by separate disk 
apparatuses. With this embodiment, the use of such 
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separate disk apparatuses makes it possible to apply 
the present invention not only for the purpose of snap 
shot utilization but also for the purpose of mirroring of 
data to remote sites. An explanation will be given of 
those portions different from the first embodiment. 
[0088] As shown in Fig. 7 the system of this embodi- 
ment has a computer 1 00, disk array apparatus 201 , and 
disk array apparatus 202. This system is different from 
that of the first embodiment in that the former has a plu- 
rality of disk array apparatuses. 

[0089] A difference of the computer 1 00 from that of 
the first embodiment is that this computer has an FC 
interface 190 and is connected to the remaining appa- 
ratus through the FC interface 190. 
[0090] A difference of the disk array apparatus 201 
over the disk array apparatus 200 of the first embodi- 
ment is that the disk device assembly 252 and m-RAID 
control subprogram 237 are removed away from the 
disk array apparatus 200. Another difference is that a 
command issuance subprogram 238 which issues a 
command or commands in order to perform data trans- 
fer relative to the other disk array apparatus or the like 
is provided within the snap shot management program 
221. In addition, the disk array apparatus 202 has an 
FC interface 290 in place of the SCSI interface 240 and 
is connected to the other apparatus via the FC interface 
290. 

[0091] A difference of the disk array apparatus 202 
over the disk array apparatus 200 of the first embodi- 
ment is as follows: the disk device assembly 251 and 
snap shot management program 221 are removed away 
from the disk array apparatus 200, with a disk array pro- 
gram 223 provided in a memory 220. Additionally the 
disk array apparatus 202 has an FC interface 290 as an 
alternative to the SCSI interface 240 and is connected 
to the other apparatus via the FC interface 290. 
[0092] The disk array program 223 has its disk access 
subprogram 230 and m-RAID control subprogram 237, 
which are substantially the same as those of Fig. 1 of 
the first embodiment. 

[0093] The command issuance subprogram 238 of 
the disk array apparatus 201 issues to the disk array 
apparatus 202 a command for access to an LU 262 with- 
in the disk array apparatus 202 by way of a fiber channel 
switch 410. Accordingly, the disk array apparatus 201 
operates while handling as the mirror secondary LU an 
LU 262 residing in the disk array apparatus 202 as con- 
nected via the fibre channel switch 41 0 in a similar way 
to that of the first embodiment. Similarly the other pro- 
gram or programs execute copying or the like of data at 
the LU 261 and LU 262 by way of the fibre channel 
switch 410. 

[0094] Additionally an operation of the snap shot man- 
agement program 221 in case the computer 1 00 gives 
access to the data of the LU 261 existing in the disk array 
apparatus 201 may be arranged so that only the mirror 
primary LU 261 is subjected to reading even where the 
LU 261 and the LU 262 acting as the mirror secondary 



LU are identical in content to each other. 
[0095] According to this embodiment, in the plurality 
of disk array apparatuses implemented to operate u nder 
the duplex/mirroring architecture, in case n and m are 
5 set at integers greater than or equal to 2 and are of dif- 
ferent values, it becomes possible to assembly the disk 
array having a memory region of the original data and 
the disk array having a memory region for provision as 
a snap shot into disk arrangements of nD+1P and 
mD+1P respectively. This in turn makes it possible to 
arrange each disk array apparatus to employ a flexible 
configuration. 

[0096] It must be noted that although in this embodi- 
ment the interface for connection between the computer 
1 00, disk array apparatus 201 and disk array apparatus 
202 is designed by a fibre channel, it may be other in- 
terfaces such as for example SCSI, interfaces having 
compatibilities with the Internet. 

[0097] So far, the first and second embodiments have 
been explained. 

[0098] It is noted that in the present invention, either 
one of the mirror primary LU and the mirror secondary 
LU or both may be designed to have an arrangement of 
RAID levels other than the RAID 5. In this case the 
n-RAID control subprogram 236 for performing RAID 
control of nD+1 P and the m-RAID control subprogram 
237 for performing RAID control of mD+1 P may be ar- 
ranged to execute control in away pursuant to the RAID 
levels of the mirror primary LU and mirror secondary LU 
respectively. 

[0099] Also note that the present invention is also ap- 
plicable to multiplex mirroring architectures employing 
a plurality of mirror secondary LUs. In this case, acertain 
number of update bit columns of the update position 
management table 222 corresponding to the mirror sec- 
ondary LUs are provided for causing the LU mirror sub- 
program 231 to perform an operation for duplexing an 
access event to the mirror primary LU into the plurality 
of mirror secondary LUs. Additionally such multiplexed 
mirror secondary LUs are arranged by a disk array of 
tD+1 P, where t is a given integer greater than or equal 
to 2. And, design the disk array apparatus to include 
therein a RAID controller capable of controlling the disk 
array with this tD+1 P arrangement. Note here that more 
than one of the mirror secondary LUs may have a RAID 
arrangement different from the ND+1 P arrangement of 
the mirror primary LU. 

[0100] As has been described above, in accordance 
with the present invention, in a disk array as implement- 
ed to operate based on duplex/mirroring schemes for 
snap shot acquisition, it becomes possible to design a 
disk array having its memory region of the original data 
and a disk array having a memory region for provision 
as a snap shot into disk arrangements of nD+1 P and 
mD+1 P respectively, where "n" and "m" are different in- 
tegers more than or equal to 2, which in turn makes it 
possible to permit each disk array to employ a mutually 
flexible arrangement. 
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[01 01 ] It will be further understood by those skilled in 
the art that the foregoing description has been made on 
embodiments of the invention and that various changes 
and modifications may be made in the invention without 
departing from the spirit of the invention and scope of 5 
the appended claims. 

Claims 

10 

1 . A method for copying data in a memory device sys- 
tem having a plurality of memory devices as parti- 
tioned into a group of n memory devices (271-275) 
and a group of m memory devices (281-287), said 
method including the steps of: 1 $ 

reading from said n memory devices (271 -275) 
data with a length required for preparation of 
redundant data; 

forming redundant data from the read data; and 20 
storing said read data and said redundant data 
in said m memory devices (281-287). 

2. The method according to claim 1 wherein at said 
step of storing, only part of said read data is stored 25 
in said m memory devices (281-287). 

3. A method for copying data in a memory device sys- 
tem being connected to external apparatus and 
having a plurality of memory devices as partitioned 30 
into n memory devices (271 -275) and m memory 
devices (281 -287), said method including the steps 

of: 

duplexing and storing data as sent from said 35 
external apparatus in said n memory devices 
and said m memory devices; 
halting duplex of data based on an instruction 
from said external apparatus; 
storing the data as sent from said external ap- *o 
paratus during interruption of data duplex in 
said n memory devices while recording infor- 
mation as to a storage location; 
restarting data duplex based on an instruction 
from said external apparatus; 45 
reading data out of said n memory devices in 
units of m-1 items; 

forming redundant data from the data of m-1 
unit; and 

storing in said m memory devices certain data 5° 
of said data of m-1 unit as designated by the 
recorded information along with said redundant 
data. 

4. A memory device system including: 55 

a plurality of memory devices as partitioned into 
n memory devices (271-275) and m memory 



devices (281-287); 

a controller (250) for control of said plurality of 
memory devices; 

n control means (236) for controlling said n 
memory devices; and 

m control means (237) for control of said m 
memory devices, wherein when copying data 
from said n memory devices to said m memory 
devices said n control means reads data of m- 
1 unit from said n memory devices whereas 
said m control means forms redundant data 
based on the m-1 unit read data to thereby store 
any one of said m-1 unit read data and said re- 
dundant data in any one of said m memory de- 
vices. 

5. The system according to claim 4 wherein said unit 
is a predetermined data length with a logical block 
address as a reference. 

6. The system according to claim 4 further including: 

an interface connected to external apparatus; 
duplex means for duplexing and storing data in 
said n memory devices (271 -275) and said m 
memory devices (281-287); 
means for interrupting said duplex means in ac- 
cordance with an instruction from said external 
apparatus; and 

update management means for recording infor- 
mation as to a location whereat data being input 
from said interface is to be stored in said n 
memory devices during interruption of said du- 
plex means, 

wherein said m control means (237) stores 
any one of said m-1 unit read data in any one of said 
m memory devices on the basis of information as 
stored in said update management means. 

7. A memory device system including: 

a plurality of memory devices as partitioned into 
n memory devices (271-275) and m memory 
devices (281-287); 

a controller (250) for control of said plurality of 
memory devices; 

n control means (236) for controlling said n 
memory devices; 

m control means (237) for controlling said m 
memory devices; and 

data duplex means for duplexing and storing 
data in said n memory devices and said m 
memory devices. 

8. The system according to claim 7 wherein n and m 
are different integers. 
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9. A computer system comprising a first memory de- 
vice system (201) with n memory devices 
(271-275); and 

a second memory device system (202) being 
connected to said first memory device system and 5 
having m memory devices (281 -287), 

wherein said first memory device system 
(201) includes means for reading data of m-1 unit 
out of said n memory devices; and 

said second memory device system (202) in- 
cludes formation means for forming redundant data 
based on the m-1 unit data as read by said first 
memory device system, and means for storing said 
redundant data as formed by said formation means 
and said m-1 unit read data in said m memory de- 
vices. 

10. A computer system comprising: 

a computer (100); and 

a memory device system (200) having a plural- 
ity of storage media, wherein 
said memory device system (200) includes: 



as said mirror secondary LU is made up of mD+1 P, 
and wherein m and n are integers more than or 
equal to two and are of different values. 

1 2. The computer system according to claim 1 0 where- 
in said mirror resynchronous subprogram (232) ex- 
ecutes processing for establishing content coinci- 
dence by copying the data of said recorded update 
position from said mirror primary LU (261) to said 
mirror secondary LU (262) and wherein said 
m-RAID control subprogram (237) performs 
processing of reading data out of said mirror prima- 
ry LU to thereby permit assortment of data of a 
stripe array of said mirror secondary LU including 
the data of said recorded updated position. 

13. A computer system comprising: 

a computer (1 00); and 

a first memory device system (201 ) and a sec- 
ond memory device system (202) each having 
a plurality of storage media, wherein 
said first memory device system (201) includes: 
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a mirror primary LU (261); 25 
a mirror secondary LU (262); 
an n-RAID control subprogram (236) for 
performing RAID control of the mirror pri- 
mary LU; 

an m-RAID control subprogram (237) for 30 
performing RAID control of the mirror sec- 
ondary LU; 

an LU mirror subprogram (231) for writing 
for duplex purposes said data into said mir- 
ror primary LU and said mirror secondary 35 
LU when said computer issues a data write 
request; 

a non-mirror event update monitor subpro- 
gram (234) for monitoring data update with 
respect to said mirror primary LU upon in- <*o 
terruption of duplexing of said mirrorprima- 
ry LU and said mirror secondary LU; 
a non-mirror event update position man- 
agement subprogram (235) for recording 
an update position of said data update with 45 
respect to said mirror primary LU; and 
a mirror resynchronous subprogram (232) 
for copying data of the recorded update po- 
sition from said mirror primary LU to said 
mirror secondary LU to thereby establish so 
content coincidence, and said mirror pri- 
mary LU and said mirror secondary LU are 
different from each other in arrangement of 
redundant array of inexpensive disks 
("RAID"). 55 

1 1 . The computer system according to claim 1 0 where- 
in said mirror primary LU is formed of nD+1 P where- 



a mirror primary LU (261); 
an n-RAID control subprogram (236) for 
performing RAID control of said mirror pri- 
mary LU; 

an LU mirror subprogram (231 ) for writing 
for duplex purposes said data into said mir- 
ror primary LU and a mirror secondary LU 
when said computer issues a data write re- 
quest; 

a non-mirror update monitor subprogram 
(234) for monitoring data update with re- 
spect to said mirror primary LU during in- 
terruption of duplex of said mirror primary 
LU and said mirror secondary LU; 
a non-mirror event update position man- 
agement subprogram (235) for recording 
an update position of said data update with 
respect to said mirror primary LU; 
a mirror resynchronous subprogram (232) 
for copying data of said recorded update 
position from said mirror primary LU to said 
mirror secondary LU to thereby permit es- 
tablishment of content coincidence; and 
a command issuance subprogram (238) 
for issuing a command for execution of da- 
ta transfer relative to the second external 
memory device; and 

said second memory device system (202) 
includes: 

a mirror secondary LU (262); and 
an m-RAID control subprogram (237) 
for performing RAID control of said 
mirror secondary LU, and said mirror 
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primary LU and said mirror secondary 
LU are different in RAID level from 
each other. 

14. The computer system according to claim 13 where- 5 
in said mirror primary LU is formed of nD+1 P where- 
as said mirror secondary LU is made up of mD+1 P, 
and wherein m and n are integers of more than or 
equal to two and are different in value from each 
other. 10 
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